chat-sidebar.scss 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365
  1. .chat-sidebar {
  2. display: flex;
  3. flex-direction: column;
  4. height: 100%;
  5. background: var(--bg-page);
  6. position: relative;
  7. .chat-header {
  8. display: flex;
  9. align-items: center;
  10. justify-content: space-between;
  11. padding: 2px 12px;
  12. background: var(--bg-subtle);
  13. border-bottom: 1px solid var(--border-default);
  14. flex-shrink: 0;
  15. .chat-header-title {
  16. font-size: 0.875rem;
  17. font-weight: 600;
  18. color: var(--text-primary);
  19. }
  20. .chat-header-actions {
  21. display: flex;
  22. align-items: center;
  23. gap: 4px;
  24. .chat-participant-count {
  25. display: flex;
  26. align-items: center;
  27. gap: 4px;
  28. padding: 4px 8px;
  29. border: none;
  30. background: transparent;
  31. font-size: 0.75rem;
  32. color: var(--text-secondary);
  33. cursor: pointer;
  34. border-radius: 4px;
  35. transition: background 0.15s, color 0.15s;
  36. svg {
  37. font-size: 0.8125rem;
  38. }
  39. span {
  40. font-weight: 500;
  41. }
  42. &:hover {
  43. background: var(--border-default);
  44. color: var(--text-primary);
  45. }
  46. }
  47. > button:not(.chat-participant-count),
  48. .chat-menu-wrapper > button {
  49. display: flex;
  50. align-items: center;
  51. justify-content: center;
  52. width: 32px;
  53. height: 32px;
  54. border: none;
  55. background: transparent;
  56. cursor: pointer;
  57. color: var(--text-secondary);
  58. border-radius: 4px;
  59. transition: background 0.15s, color 0.15s;
  60. &:hover {
  61. background: var(--border-default);
  62. color: var(--text-primary);
  63. }
  64. }
  65. }
  66. .chat-menu-wrapper {
  67. position: relative;
  68. }
  69. .chat-menu {
  70. position: absolute;
  71. top: 100%;
  72. right: 0;
  73. min-width: 150px;
  74. background: var(--bg-page);
  75. border: 1px solid var(--border-default);
  76. border-radius: 3px;
  77. z-index: 10;
  78. overflow: hidden;
  79. button {
  80. display: flex;
  81. align-items: center;
  82. gap: 8px;
  83. width: 100%;
  84. padding: 10px 14px;
  85. border: none;
  86. background: transparent;
  87. cursor: pointer;
  88. font-size: 0.8125rem;
  89. color: var(--text-primary);
  90. text-align: left;
  91. transition: background 0.15s;
  92. svg {
  93. width: 14px;
  94. color: var(--text-muted);
  95. }
  96. &:hover {
  97. background: var(--bg-subtle);
  98. }
  99. &:disabled {
  100. color: var(--border-strong);
  101. cursor: not-allowed;
  102. svg {
  103. color: var(--border-strong);
  104. }
  105. &:hover {
  106. background: transparent;
  107. }
  108. }
  109. }
  110. }
  111. }
  112. .chat-messages {
  113. flex: 1;
  114. overflow-y: auto;
  115. padding: 8px 12px;
  116. display: flex;
  117. flex-direction: column;
  118. gap: 4px;
  119. &::-webkit-scrollbar {
  120. width: 4px;
  121. }
  122. &::-webkit-scrollbar-thumb {
  123. background: var(--border-strong);
  124. border-radius: 2px;
  125. }
  126. .chat-system {
  127. text-align: center;
  128. font-size: 0.75rem;
  129. color: var(--text-muted);
  130. padding: 4px 0;
  131. }
  132. .chat-message {
  133. display: flex;
  134. align-items: baseline;
  135. gap: 6px;
  136. padding: 3px 0;
  137. line-height: 1.4;
  138. word-break: break-word;
  139. .chat-message-time {
  140. font-size: 0.625rem;
  141. color: var(--text-muted);
  142. flex-shrink: 0;
  143. }
  144. .chat-message-name {
  145. font-size: 0.8125em;
  146. font-weight: 600;
  147. color: var(--text-secondary);
  148. flex-shrink: 0;
  149. max-width: 80px;
  150. overflow: hidden;
  151. text-overflow: ellipsis;
  152. white-space: nowrap;
  153. }
  154. .chat-message-content {
  155. font-size: 1em;
  156. color: var(--text-primary);
  157. }
  158. }
  159. }
  160. .chat-input-area {
  161. flex-shrink: 0;
  162. border-top: 1px solid var(--border-default);
  163. padding: 8px 10px;
  164. background: var(--bg-elevated);
  165. .chat-input-row {
  166. display: flex;
  167. gap: 6px;
  168. input {
  169. flex: 1;
  170. padding: 8px 10px;
  171. border: 1px solid var(--border-default);
  172. border-radius: 4px;
  173. font-size: 0.8125rem;
  174. outline: none;
  175. transition: border-color 0.15s;
  176. &:focus {
  177. border-color: #F7931A;
  178. }
  179. &:disabled {
  180. background: var(--bg-subtle);
  181. color: var(--text-muted);
  182. }
  183. }
  184. button {
  185. display: flex;
  186. align-items: center;
  187. justify-content: center;
  188. width: 36px;
  189. height: 36px;
  190. border: none;
  191. background: var(--brand-orange);
  192. color: #fff;
  193. border-radius: 4px;
  194. cursor: pointer;
  195. flex-shrink: 0;
  196. transition: background 0.15s;
  197. &:hover {
  198. background: var(--brand-orange-hover);
  199. }
  200. &:disabled {
  201. background: var(--border-strong);
  202. cursor: not-allowed;
  203. }
  204. }
  205. .chat-donate-btn {
  206. background: #FFD700;
  207. color: #333;
  208. &:hover {
  209. background: #FFC400;
  210. }
  211. }
  212. }
  213. .chat-login-notice {
  214. text-align: center;
  215. font-size: 0.8125rem;
  216. color: var(--text-muted);
  217. padding: 2px 0;
  218. a {
  219. color: var(--brand-orange);
  220. font-weight: 600;
  221. text-decoration: underline;
  222. &:hover {
  223. color: var(--brand-orange-hover);
  224. }
  225. }
  226. }
  227. }
  228. // 참여자 목록 오버레이
  229. .chat-participants-overlay {
  230. position: absolute;
  231. top: 0;
  232. left: 0;
  233. right: 0;
  234. bottom: 0;
  235. background: var(--overlay-color);
  236. z-index: 11;
  237. }
  238. // 참여자 목록 패널
  239. .chat-participants-dialog {
  240. position: absolute;
  241. top: 50%;
  242. left: 50%;
  243. transform: translate(-50%, -50%);
  244. width: calc(100% - 24px);
  245. max-height: 60%;
  246. background: var(--bg-page);
  247. border-radius: 8px;
  248. box-shadow: 0 8px 24px var(--shadow-color);
  249. overflow: hidden;
  250. z-index: 12;
  251. .chat-participants-header {
  252. display: flex;
  253. align-items: center;
  254. justify-content: space-between;
  255. padding: 12px 16px;
  256. border-bottom: 1px solid var(--border-default);
  257. background: var(--bg-subtle);
  258. h3 {
  259. font-size: 0.875rem;
  260. font-weight: 600;
  261. color: var(--text-primary);
  262. margin: 0;
  263. }
  264. button {
  265. display: flex;
  266. align-items: center;
  267. justify-content: center;
  268. width: 28px;
  269. height: 28px;
  270. border: none;
  271. background: transparent;
  272. cursor: pointer;
  273. font-size: 1.25rem;
  274. color: var(--text-secondary);
  275. border-radius: 4px;
  276. &:hover {
  277. background: var(--border-default);
  278. color: var(--text-primary);
  279. }
  280. }
  281. }
  282. .chat-participants-list {
  283. list-style: none;
  284. margin: 0;
  285. padding: 0;
  286. overflow-y: auto;
  287. max-height: calc(100% - 52px);
  288. li {
  289. display: flex;
  290. align-items: center;
  291. gap: 8px;
  292. padding: 10px 16px;
  293. font-size: 0.8125rem;
  294. color: var(--text-primary);
  295. border-bottom: 1px solid var(--bg-subtle);
  296. &:last-child {
  297. border-bottom: none;
  298. }
  299. .chat-participant-icon {
  300. color: var(--text-muted);
  301. font-size: 0.75rem;
  302. }
  303. }
  304. .chat-participants-empty {
  305. justify-content: center;
  306. color: var(--text-muted);
  307. padding: 24px 16px;
  308. }
  309. .chat-participants-guest {
  310. color: var(--text-muted);
  311. font-style: italic;
  312. }
  313. }
  314. }
  315. }